<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>pg_stats</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="SECT1">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="view-pg-shadow.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="catalogs.html">快退</a></td><td width="60%" align="center" valign="bottom">章43. 系统表</td><td width="10%" align="right" valign="top"><a href="catalogs.html">快进</a></td><td width="10%" align="right" valign="top"><a href="view-pg-tables.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<div class="SECT1"><h1 class="SECT1"><a name="VIEW-PG-STATS">43.46. <tt class="STRUCTNAME">pg_stats</tt></a></h1><a name="AEN66277"></a>
<p><tt class="STRUCTNAME">pg_stats</tt> 提供对存储在 <a href="catalog-pg-statistic.html"><tt class="STRUCTNAME">pg_statistic</tt></a> 表里面的信息的访问。这个视图允许只访问那些在 <tt class="STRUCTNAME">pg_statistic</tt> 里面对应用户有权限读取的表的数据行，因此可以安全地允许公众访问这个视图。</p>
<p><tt class="STRUCTNAME">pg_stats</tt> 也设计成把信息以一种更易读的方式出现的形式，它比下层的系统表更容易阅读，代价就是如果在 <tt class="STRUCTNAME">pg_statistic</tt> 里定义了新的数据槽位，那么必须扩展它的视图定义。</p>
<div class="TABLE"><a name="AEN66287"></a>
<p><b>表43-46. <tt class="STRUCTNAME">pg_stats</tt> 字段</b></p>
<table border="1" class="CALSTABLE"><col><col><col><col>
<thead>
<tr><th>名字</th><th>类型</th><th>引用</th><th>描述</th></tr>
</thead>
<tbody>
<tr><td><tt class="STRUCTFIELD">schemaname</tt></td><td><tt class="TYPE">name</tt></td><td><tt class="LITERAL"><a href="catalog-pg-namespace.html"><tt class="STRUCTNAME">pg_namespace</tt></a>.nspname</tt></td><td>包含此表的模式名字</td></tr>
<tr><td><tt class="STRUCTFIELD">tablename</tt></td><td><tt class="TYPE">name</tt></td><td><tt class="LITERAL"><a href="catalog-pg-class.html"><tt class="STRUCTNAME">pg_class</tt></a>.relname</tt></td><td>表的名字</td></tr>
<tr><td><tt class="STRUCTFIELD">attname</tt></td><td><tt class="TYPE">name</tt></td><td><tt class="LITERAL"><a href="catalog-pg-attribute.html"><tt class="STRUCTNAME">pg_attribute</tt></a>.attname</tt></td><td>这一行描述的字段的名字</td></tr>
<tr><td><tt class="STRUCTFIELD">null_frac</tt></td><td><tt class="TYPE">real</tt></td><td>&nbsp;</td><td>记录中字段为空的百分比</td></tr>
<tr><td><tt class="STRUCTFIELD">avg_width</tt></td><td><tt class="TYPE">integer</tt></td><td>&nbsp;</td><td>字段记录以字节记的平均宽度</td></tr>
<tr><td><tt class="STRUCTFIELD">n_distinct</tt></td><td><tt class="TYPE">real</tt></td><td>&nbsp;</td><td>如果大于零，就是在字段中独立数值的估计数目。如果小于零，就是独立数值的数目被行数除的负数。用负数形式是因为 <tt class="COMMAND">ANALYZE</tt> 认为独立数值的数目是随着表增长而增长；正数的形式用于在字段看上去好像有固定的可能值数目的情况下。比如，-1 表示一个唯一字段，独立数值的个数和行数相同。</td></tr>
<tr><td><tt class="STRUCTFIELD">most_common_vals</tt></td><td><tt class="TYPE">anyarray</tt></td><td>&nbsp;</td><td>一个字段里最常用数值的列表。如果看上去没有啥数值比其它更常见，则为 NULL</td></tr>
<tr><td><tt class="STRUCTFIELD">most_common_freqs</tt></td><td><tt class="TYPE">real[]</tt></td><td>&nbsp;</td><td>一个最常用数值的频率的列表，也就是说，每个出现的次数除以行数。如果 <tt class="STRUCTFIELD">most_common_vals</tt> 是 NULL ，则为 NULL</td></tr>
<tr><td><tt class="STRUCTFIELD">histogram_bounds</tt></td><td><tt class="TYPE">anyarray</tt></td><td>&nbsp;</td><td>一个数值的列表，它把字段的数值分成几组大致相同热门的组。如果在 <tt class="STRUCTFIELD">most_common_vals</tt> 里有数值，则在这个饼图的计算中省略。如果字段数据类型没有 <tt class="LITERAL">&lt;</tt> 操作符或者 <tt class="STRUCTFIELD">most_common_vals</tt> 列表代表了整个分布性，则这个字段为 NULL 。</td></tr>
<tr><td><tt class="STRUCTFIELD">correlation</tt></td><td><tt class="TYPE">real</tt></td><td>&nbsp;</td><td>统计与字段值的物理行序和逻辑行序有关。它的范围从 -1 到 +1 。在数值接近 -1 或者 +1 的时候，在字段上的索引扫描将被认为比它接近零的时候开销更少，因为减少了对磁盘的随机访问。如果字段数据类型没有 <tt class="LITERAL">&lt;</tt> 操作符，那么这个字段为 NULL 。</td></tr>
</tbody>
</table>
</div>
<p>在 <tt class="STRUCTFIELD">most_common_vals</tt> 和 <tt class="STRUCTFIELD">histogram_bounds</tt> 数组里的元素的最大数目可以用 <tt class="COMMAND">ALTER TABLE SET STATISTICS</tt> 命令一个一个字段地设置，或者通过设置运行时参数 <a href="runtime-config-query.html#GUC-DEFAULT-STATISTICS-TARGET">default_statistics_target</a> 全局地设置。</p>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="view-pg-shadow.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="view-pg-tables.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top"><tt class="STRUCTNAME">pg_shadow</tt></td><td width="34%" align="center" valign="top"><a href="catalogs.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top"><tt class="STRUCTNAME">pg_tables</tt></td></tr>
</table>
</div>
</body></html>